草庐IT

php - postgresql 在查询中插入空值

全部标签

ruby-on-rails - 数组上的 rails where() sql 查询

我会尽可能详细地解释这一点。我对用户帖子有疑问:@selected_posts=Posts.where(:category=>"棒球")我想写下面的语句。这是伪术语:User.where(用户在@selected_posts中有帖子)请记住,我设置了多对多关系,因此post.user可用。有什么想法吗?/编辑@posts_matches=User.includes(@selected_posts).map{|user|[user.company_name,user.posts.count,user.username]}.sort基本上,我需要上面的工作,以便它使用在selected_p

ruby - 使用 Nokogiri 插入和删除 XML 节点和元素

我想提取XML文件的一部分,并记下我提取了该文件中的某些部分,例如“这里提取了一些东西”。我正尝试用Nokogiri来做这件事,但似乎并没有真正记录如何:删除的所有child更改inner_text那个完整的元素有什么线索吗? 最佳答案 Nokogiri让这一切变得非常简单。使用thisdocument例如,以下代码将找到所有vitamins标签,删除它们的子标签(以及子标签的子标签等),并将它们的内部文本更改为“Childrenremoved”。require'nokogiri'io=File.open('sample.xml',

ruby - mongoid查询缓存

Rails的ActiveRecord有一个称为查询缓存(ActiveRecord::QueryCache)的功能,它在请求的生命周期内保存SQL查询的结果。虽然我不太熟悉实现的内部结构,但我认为它将查询结果保存在Rackenv中的某个位置,该结果在请求结束时被丢弃。不幸的是,Mongoid当前不提供这样的功能,并且由于某些查询隐式发生(引用)这一事实而加剧了这种情况。我正在考虑实现此功能,而且我很好奇,应该在何处以及如何连接Mongoid(或者,也许是mongo驱动程序?)以实现此功能。 最佳答案 Mongoid有缓存,在http:

sql - 使用 SQL IN 和 SQL OR 运算符的 Rails 3 ActiveRecord 查询

我正在使用“where”语法编写一个Rails3ActiveRecord查询,它同时使用了SQLIN和SQLOR运算符,但不知道如何同时使用它们。此代码有效(在我的用户模型中):Question.where(:user_id=>self.friends.ids)#note:self.friends.idsreturnsanarrayofintegers但是这段代码Question.where(:user_id=>self.friends.idsOR:target=>self.friends.usernames)返回这个错误syntaxerror,unexpectedtCONSTANT,

ruby-on-rails - 如何修复 Rails 中 pg_attribute 表的缓慢隐式查询

在我们的生产环境中,我们注意到Rails应用程序频繁出现峰值(大约每1小时一次)。深入挖掘,这是由于以下查询在单个HTTP请求中累计运行时间超过1.5秒(称为100倍)。SELECTa.attname,format_type(a.atttypid,a.atttypmod),pg_get_expr(d.adbin,d.adrelid),a.attnotnull,a.atttypid,a.atttypmodFROMpg_attributeaLEFTJOINpg_attrdefdONa.attrelid=d.adrelidANDa.attnum=d.adnumWHEREa.attrelid=

ruby - 为什么 `return a or b` 在 Ruby 中是空值表达式错误?

这很好:deffooaorbend这也很好:deffooreturna||bend这将返回空值表达式:deffooreturnaorbend为什么?它甚至没有被执行;它没有通过语法检查。voidvalueexpression是什么意思? 最佳答案 returnaorb被解释为(returna)orb,因此returna的值对于计算(returna)或b的值,但由于return永远不会在原地留下一个值(因为它从那个位置转义),所以它不是为了返回有效值而设计的在原来的位置。因此,整个表达式只剩下(some_void_value)或b,并

ruby-on-rails - 我可以在 Ruby on Rails 上编写 PostgreSQL 函数吗?

我们正在启动一个基于RubyonRails的项目。我们曾经使用Perl和PostgreSQL函数,使用Rails和ActiveRecord我还没有看到我们应该如何在PostgreSQL中创建函数并使用ActiveRecord和模型保存记录。我知道我们可以在PostgreSQL中手动创建它,但ActiveRecord的“魔力”在于可以使用所有模型重新创建数据库。有什么方法可以使用Rails创建PostgreSQL函数并将其保存在模型中吗? 最佳答案 这部分问题:IknowwecancreateitmanuallyinPostgreSQ

ruby - 自动记录 DataMapper 查询

我正在使用DataMapper在Sinatra中开发一个简单的应用程序。我想查看DM为我的各种链式查找器等创建的查询。我试过:DataMapper::Logger.new(STDOUT,:debug)在我的configuredo...endblock中,environment.rb文件会在应用程序启动时加载。我也试过:DataMapper::Logger.new('log/my-app.log',:debug)既不会从通过浏览器或通过需要我的应用程序的irbsession访问的应用程序生成日志语句。我确实看到了应用启动消息。我正在使用rackupconfig.ru在本地运行应用程序。我

ruby-on-rails - 将查询字符串附加到 url

我有一个回调url字符串params[:callback],我需要附加一个查询字符串"&result=true"并重定向用户。我发现这样做的更好方法是使用addressable但我认为代码对于这样的任务来说太大了,尤其是当我们谈论ruby​​时:callback=Addressable::URI.parse(params[:callback])query=callback.query_valuesquery[:result]='true'callback.query_values=queryredirect_tocallback.to_s是否有更优雅的方式来获得与此代码段相同的结果?

ruby-on-rails - 如何获取触发查询的代码行?

在rails3.2中是否有一种方法(一个gem、一个插件或其他东西)来知道哪一行代码触发了一个数据库查询?例如在我的日志中我有:UserLoad(0.4ms)SELECT`users`.*FROM`users`WHERE`users`.`id`=5LIMIT1如何知道触发查询的代码行?谢谢... 最佳答案 我找到了这个解决方案:moduleQueryTracedefself.enable!::ActiveRecord::LogSubscriber.send(:include,self)enddefself.append_featur